import { message } from "antd";
import axios from "axios";
import { hasToken, getToken, removeToken } from "./storage";
import history from "utils/history";
// 创建axios实例
const instance = axios.create({
  baseURL: "http://geek.itheima.net/v1_0",
  timeout: 5000,
});
// 添加请求拦截器
instance.interceptors.request.use(
  function (config) {
    // 在发送请求之前做些什么
    if (hasToken()) {
      config.headers.Authorization = `Bearer ${getToken()}`;
    }
    return config;
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  }
);

// 添加响应拦截器
instance.interceptors.response.use(
  function (response) {
    // 对响应数据做点什么
    return response.data;
  },
  function (error) {
    console.log("error: ", error);
    // 对响应错误做点什么
    // 对token过期进行统一的处理
    if (error.response.status === 401) {
      //代表token过期了
      //1 .删除token
      removeToken();
      //2.给提示消息
      message.warn("登录信息过期了");
      //3.跳转到登录页
      //4.难点:在非组件中,我们是无法使用Redirect 也无法访问history,location等对象
      console.log("history", history);
      history.push("/login");
    }
    return Promise.reject(error);
  }
);
export default instance;
